# CPE 300L DIGITAL SYSTEM ARCHITECTURE AND DESIGN LABORATORY

# LABORATORY 8 **GENERAL DATAPATH III** TIMEQUEST AND MEMORY INITIALIZATION

DEPARTMENT OF ELECTRICAL AND COMPUTER ENGINEERING UNIVERSITY OF NEVADA, LAS VEGAS

## **OBJECTIVE**

Implement a general datapath for a given algorithm.

Gain experience in setting up the timing constraints and obtain timing information for a logic circuit.

## Algorithm:

Following algorithm calculates the greatest common divisor (GCD) of two natural numbers a and b. GCD of a and b is the largest natural number that divides both a and b with a zero remainder.

```
input a,b
while a \neq b
      if a > b
            a = a - b
      else
            b = b - a
output a
```

#### LAB DELIVERIES

#### **PRELAB**

### 1. TimeQuest

Complete the TimeQuest analyzer tutorial: https://faculty.unlv.edu/eelabs/docs/guides/Altera\_Timequest.pdf

## 2. Memory initialization in Quartus II

Create the .mif file using the following tutorial:

https://facultv.unlv.edu/eelabs/docs/guides/Memory initialization tutorial.pdf



## 3. Graphs

Create a flowchart, state graph and control words for the GCD algorithm given above to implement in the general datapath.

#### PRELAB DELIVERABLES:

- Screenshot of the timing report before and after setting up timing constraints.
- Flowchart, state graph and control words for the algorithm. 3.

#### LAB EXPERIMENTS

Demonstrate each experiment to TA.

## 1. General datapath

Implement the general datapath design for the GCD algorithm shown above, you can use the general datapath code from lab 7. Implement the testbench and verify in Modelsim before testing on the DE2. Result should be displayed on the 7 segment display.

### 2. Timequest analysis

Perform the time quest analysis on experiment 1 and obtain the report on the cycle time.

#### POSTLAB REPORT

Include the following elements in your postlab report:

| Section | Element                                                                                 |                                                                           |
|---------|-----------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 1       | Theory of operation                                                                     |                                                                           |
|         | Include a brief description of every element and phenomenon that appears during the     |                                                                           |
|         | experiments.                                                                            |                                                                           |
|         | a. What is a slack in time quest analysis?                                              |                                                                           |
|         | b. Why                                                                                  | is it important to consider timing analysis in a digital circuit?         |
| 2       | Prelab report                                                                           |                                                                           |
| 3       | Results of the experiments                                                              |                                                                           |
|         | Experiment                                                                              | Experiment Results                                                        |
|         | 1                                                                                       | Verilog Code, Testbench, Waveform, Picture of DE2                         |
|         | 2                                                                                       | Screenshots of the timing analysis                                        |
| 4       | Answer the questions                                                                    |                                                                           |
|         | Question no.                                                                            | Question                                                                  |
|         | 1                                                                                       | Find out the information about the TimeQuest analyzer. Write 2 paragraphs |
|         |                                                                                         | about this tool.                                                          |
|         | 2                                                                                       | List the purposes of initializing the memory in Quartus II                |
| 5       | Conclusions                                                                             |                                                                           |
|         | Write down your conclusions, things learned, problems encountered during the lab and he |                                                                           |
|         | they were solved, etc.                                                                  |                                                                           |

# **REFERENCES**

- $1. \ Memory \ Initialization \ tutorial:$ https://faculty.unlv.edu/eelabs/docs/guides/Memory\_initialization\_tutorial.pdf
- 2. Using TimeQuest Timing Analyzer, Altera. https://faculty.unlv.edu/eelabs/docs/guides/Altera\_Timequest.pdf